草庐IT

optimization - gcc 内存对齐编译指示

全部标签

ruby - 为什么这个 Ruby 程序不将堆内存返回给操作系统?

我试图了解从Ruby堆分配的内存何时返回给操作系统。我知道Ruby永远不会返回分配给它的堆内存,但我仍然不确定堆外内存的行为。即那些不适合40字节RVALUE的对象。考虑以下分配一些大字符串然后强制进行主要GC的程序。require'objspace'STRING_SIZE=250defprint_stats(msg)puts'-------------------'putsmsgputs'-------------------'puts"RSS:#{`ps-eorss,pid|grep#{Process.pid}|grep-vgrep|awk'{print$1,"KB";}'`}"p

ruby-on-rails - 编译器未能生成可执行文件。 (运行时错误)

我最近升级到了OSMountainLion。我正在处理的项目需要gemsys-proctable作为依赖项,但是当我运行bundleinstall时,我得到:Fetchinggemmetadatafromhttps://rubygems.org/............Installingsys-proctable(0.9.2)withnativeextensionsGem::Installer::ExtensionBuildError:ERROR:Failedtobuildgemnativeextension./Users/mgriffel/.rvm/rubies/ruby-1.9.

ruby - 无法编译 ruby​​ 1.9.3

当我运行时rvminstall1.9.3--with-gcc=clang在MacOSXLion上,ruby无法编译,我在(.rvm/log/ruby-1.9.3-p374/make.log)中收到以下错误[2013-01-2916:31:05]makeCC=clangLD=ldLDSHARED=clang-dynamic-bundleCFLAGS=-O3-ggdb-Wall-Wextra-Wno-unused-parameter-Wno-parentheses-Wno-long-long-Wno-missing-field-initializers-Werror=pointer-ari

ruby-on-rails - 何时在 Ruby on Rails 中使用内存

2008年7月中旬,Memoization被添加到Rails核心。用法演示是here.关于何时应该内存方法,以及每个方法的性能影响,我还没有找到任何好的例子。Thisblogpost,例如,建议通常根本不应该使用内存。对于可能具有巨大性能影响的内容,除了提供简单教程之外似乎没有其他资源。有没有人见过在自己的项目中使用memoization?哪些因素会让您考虑内存方法?在我自己做了更多研究之后,我发现在Rails核心中使用记忆化的次数非常多。这是一个例子:http://github.com/rails/rails/blob/1182658e767d2db4a46faed35f0b1075

编译器是否对所有内联函数调用执行相同的操作?

C++编译器是否会对将两个不同的呼叫呼叫采取不同的决定?考虑这样的代码:inlinefunc(intx){returnx+(x编译器会在循环之前对呼叫和循环中的呼叫执行相同的操作?如果我们考虑了代码长度以及速度优化,则不应将循环之前的呼叫与内部的呼叫,内部的呼叫。看答案这取决于您的编译器。假设你用gcc5.4.0和-O2优化水平。内部的第一行main功能inty=func(1)+func(2)+func(3)+func(4);将根据整数文字和内部的代码在编译时间计算for循环将被内衬。但是,如果您使用另一个编译器或另一个优化级别,则结果可能会有所不同。如果您希望检查代码的组件输出,请使用编译器

ruby - 如何编译 Ruby?

是否有一种工具可以让我编译Ruby代码使其运行得更快?例如,我听说有一个Python的工具叫“pyc”,它可以让我们编译代码,使其运行速度提高10倍。 最佳答案 简单的答案是您不能,至少对于MRI1.8(标准)。这是因为1.8通过遍历抽象语法树来工作。Python、Ruby1.9、JRuby和Rubinius使用字节码,这允许编译为中间表示(字节码)。从MRIRuby2.3开始,这变得很容易,请参阅answer下面。使用Rubinius,您可以按照这篇文章中的描述进行操作:http://rubini.us/2011/03/17/ru

ruby - 你有什么策略来保持低内存使用率?

Ruby真的很耗费内存——但也值得每一点。您如何保持低内存使用率?您是避免使用大字符串并改用较小的数组/散列,还是让垃圾收集器完成这项工作对您来说没有问题?编辑:我找到了一篇关于这个主题的好文章here-古老但仍然有趣。 最佳答案 我发现Phusion的RubyEnterpriseEdition(主线Ruby的一个分支,垃圾收集功能得到了很大改进)在内存使用方面产生了巨大的变化......此外,它们还非常容易安装(和删除),如果您发现需要)。您可以在theirwebsite上找到更多信息并下载。.

ruby - Sidekiq 在工作人员完成后不释放内存

我有大约6个Sidekiqworker执行JSON爬行。根据端点的数据集大小,它们在1分钟到4小时之间完成。特别是,观看需要4小时的长视频,我发现随着时间的推移,内存有非常轻微的增加。这不是问题,直到我想再次安排相同的worker作业。内存不会被释放并堆积起来,直到我遇到LinuxOOMKiller,它摆脱了我的Sidekiq进程。内存泄漏?我观察了ObjectSpace中不同对象的数量:ObjectSpace.each_object.inject(Hash.new(0)){|count,o|count[o.class]+=1}那里并没有真正增加,哈希集、数组等保持不变,垃圾收集器清除

ruby - 哈希或其他对象的内存大小?

在Ruby1.9.3中以字节为单位获取给定散列(或任何对象)大小的最佳方法是什么?“FindnumberofbytesaparticularHashisusinginRuby”的解决方案在1.9.3中似乎无效,因为memsize_of不在ObjectSpace的文档中. 最佳答案 ObjectSpace.memsize_ofdoeswork在1.9.3中,记录与否:putsRUBY_VERSION#=>1.9.3require'objspace'pObjectSpace.memsize_of("a"*23)#=>23pObjectS

ruby - 有人尝试过 Crystal 编程语言(机器代码编译的 Ruby)吗?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion和许多其他人一样,我始终坚信“Ruby永远不会存在纯编译器,因为该语言对于静态编译器来说过于动态,无法工作。”但我最近偶然发现了这些:TheCrystalprogramminglanguageatGitHubStaticallycompiledRuby这两个项目看起来都很有趣。它们可以为我们提供原生编译语言的速度(以及通常是商业需求的编译语言的混淆代码),同时保留Ruby的所有(或大部分)